#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using pii = pair<int, int>;
#define rep(i, a, b) for (int i = (a); i <= (b); i++)
#define per(i, a, b) for (int i = (a); i >= (b); i--)
#define endl '\n'
const int N = 25;

int n, m, flag;
bool vis[N];
void f(int s, int cnt) {
  if (cnt > m) return;
  if (cnt == m) {
    rep(i, 1, n) if (flag ^ vis[i]) cout << i << ' ';
    cout << endl;
    return;
  }
  if (s > n) return;
  if (!flag) {
    // 选择的在前
    vis[s] = 1;
    f(s + 1, cnt + 1);
    vis[s] = 0;
    f(s + 1, cnt);
  } else {
    // 选择的在前
    f(s + 1, cnt);
    vis[s] = 1;
    f(s + 1, cnt + 1);
    vis[s] = 0;
  }
}

int main() {
  ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
  cin >> n >> m;
  if (m * 2 > n) flag = 1, m = n - m;
  f(1, 0);
  return 0;
}